package com.zzl.car.util;

import com.zzl.car.entity.User;
import io.jsonwebtoken.Claims;
import io.jsonwebtoken.JwtException;
import io.jsonwebtoken.Jwts;
import io.jsonwebtoken.SignatureAlgorithm;
import org.springframework.util.StringUtils;

import java.time.Duration;
import java.util.Date;

/*
* Jwt 工具类，用来生成 token 和解析token
* */
public final class ZdpJwtUtil {
    //秘钥 防止JWT被篡改
    private final static String secretKey = "zdpupupup";
    //过期时间  Duration
    private final static Duration expiration = Duration.ofHours(2);

    //生成JWT
    public static String generate(String username) {
        // 过期时间
        Date expiryDate = new Date(System.currentTimeMillis() + expiration.toMillis());
        String re = Jwts.builder()
                .setSubject(username) // 放入用户名（尽量放用户的标识）
                .setIssuedAt(new Date()) // 设置JWT签发时间
                .setExpiration(expiryDate)  // 设置过期时间
                .signWith(SignatureAlgorithm.HS512, secretKey) // 设置加密算法和秘钥
                .compact();
        System.out.println("==========");
        System.out.println(re);
        return re;
    }
    //解析JWT
    public static Claims parse(String token) {
        // 如果是空字符串直接返回null
        if (!StringUtils.hasLength(token)) {
            return null;
        }

        // 这个Claims对象包含了许多属性，比如签发时间、过期时间以及存放的数据等
        //解析出该对象
        Claims claims = null;
        // 解析失败了会抛出异常，所以我们要捕捉一下。token过期、token非法都会导致解析失败
        try {
            //根据秘钥和token 来解析
            claims = Jwts.parser()
                    .setSigningKey(secretKey) // 设置秘钥
                    .parseClaimsJws(token)
                    .getBody();
        } catch (JwtException e) {
            // 这里应该用日志输出
            e.printStackTrace();
            System.err.println("解析失败！");
        }
        return claims;
    }
}
